

Patent Number: 75201, 62630, 61007 (R.O.C)

**Patent Pending: 83216083 (R.O.C)** 

#### GENERAL DESCRIPTION

EM73492 is an advanced single chip CMOS 4-bit micro-controller. It contains 4K-byte ROM, 244-nibble RAM, 4-bit ALU, 13-level subroutine nesting, 22-stage time base, two independent 12-bit timer/counters and one data pointer (DP) for the kernel function, and the EM73492 also contains 6 interrupt sources, 10 I/O ports (including 1 output port, 2 input ports and 7 bidirection ports) and a serial bidirection interface (SIO).

For the application in the telecom product, EM73492 also supports user the beep tone and DTMF function and there is another additional 512x4 bits RAM for the repertory dailing data storage.

Except low-power consumption and high speed, EM73492 also has sleep and hold mode operation for power saving function.

EM73492 is suitable for appliaction in telecom products and family appliances.

#### **FEATURES**

• Operation voltage : 2.2V to 5.5V (clock frequency : 480 KHz to 4 MHz)

• Clock source : Single clock system available for resonator or crystal and external clock source

by mask option.

• Frequency selection : 480K/960K/3.58M/3.84M/4M Hz decided by mask option.

Instruction set
 Instruction cycle time
 Up to 2µs for 4 MHz.

ROM capacity : 4K X 8 bits.
RAM capacity : 244 X 4 bits.
Input port : 2 ports (5-bit)

Port 0 : Pull-up or pull-down resistor available by mask option for input port function.

Pull-up resistor available by mask option for used as sleep releasing port.

Port 14 : Pull-up resistor available by mask option.

Output port
 Bidirection I/O port
 1 port (3-bit) (push-up or open-drain type decided by mask option).
 7 ports (27-bit) (push-pull or open-drain type decided by mask option).

• 12 bits timer/counter : Two 12-bit timer/counters are programmable for timer, event counter and pulse

width measurement.

Built-in time base counter: 22 stages.
Subroutine nesting: Up to 13 levels.

• Interrupt : External . . . . 2 input interrupt sources.

Internal . . . . . 2 Timer overflow interrupts.

1 Time base interrupt.

1 SIO interrupt.

• SIO function : Serial bidirection interface can transfer 4-bit data in or out by external or internal

clock with falling or rising edge shift mode.

• Beep tone function.

• DTMF tone function.

• Extended RAM of 512 nibbles for repertory dailing data storage.

• Power saving function : Sleep function, CPU hold internal state and stop oscillating.

Hold function, CPU hold internal state and oscillator still working.



Package type : EM73492AP DIP 28 pins.
 EM73492CR SDIP 42 pins.
 EM73492DQ QFP 44 pins.

#### PIN ASSIGNMENTS





# **FUNCTION BLOCK DIAGRAM**



# PIN DESCRIPTIONS

| Symbol              | Pin-type | Function                                                                             |
|---------------------|----------|--------------------------------------------------------------------------------------|
| V <sub>DD</sub>     |          | Power supply (+)                                                                     |
| V <sub>ss</sub>     |          | Power supply (-)                                                                     |
| RESET               | RESET-A  | External reset input pin or internal reset function by mask option mask option: none |
|                     |          | pull-up                                                                              |
| XIN                 | OSC-A    | Crystal or external clock source connecting pin                                      |
| XOUT                | OSC-A    | Crystal connecting pin                                                               |
| P0(03)/WAKEUP03     | INPUT-D  | 4-bit input port with Sleep/Hold releasing and R-option function                     |
|                     |          | mask option: R-option enable, wakeup disable, none                                   |
|                     |          | R-option enable, wakeup disable, pull-up                                             |
|                     |          | R-option disable, wakeup enable, none                                                |
|                     |          | R-option disable, wakeup enable, pull-up                                             |
|                     |          | R-option disable, wakeup disable, none                                               |
|                     |          | R-option disable, wakeup disable, pull-up                                            |
|                     |          | R-option disable, wakeup disable, pull-down                                          |
| P3(03)              | I/O-A    | 4-bit bidirection I/O port                                                           |
|                     |          | mask option: open-drain                                                              |
|                     |          | push-pull                                                                            |
| P4(03),P5(03)       | I/O-F    | 4-bit bidirection I/O ports with R-option function                                   |
| P6(03),P7(03)       |          | mask option: R-option enable, push-pull                                              |
|                     |          | R-option disable, open-drain                                                         |
|                     |          | R-option disable, push-pull                                                          |
| P8.0/INT1           | I/O-C    | 2-bit bidirection I/O port with external interrupt sources input                     |
| P8.2/INT0           |          | mask option: open-drain                                                              |
|                     |          | push-pull                                                                            |
| P8.1/TRGB,P8.3/TRGA | I/O-C    | 2-bit bidirection I/O port with timer/counter A,B external input                     |
|                     |          | mask option: open-drain                                                              |
|                     |          | push-pull                                                                            |

<sup>\*</sup> This specification are subject to be changed without notice.



| Symbol        | Pin-type | Function                                                |
|---------------|----------|---------------------------------------------------------|
| P9.0/SI       | I/O-C    | 1-bit bidirection I/O pin is shared with SIO input pin  |
|               |          | mask option: open-drain                                 |
|               |          | push-pull                                               |
| P9.1/SO       | I/O-D    | 1-bit bidirection I/O pin is shared with SIO output pin |
|               |          | mask option: open-drain                                 |
|               |          | push-pull                                               |
| P9.2/SCK      | I/O-E    | 1-bit bidirection I/O pin is shared with SIO clock pin  |
|               |          | mask option: open-drain                                 |
|               |          | push-pull                                               |
| P14.0/WAKEUPE | INPUT-F  | 1-bit input pin with Sleep/Hold releasing function      |
|               |          | mask option: none                                       |
|               |          | pull-pull                                               |
| P20.0/BEEP    | OUTPUT-B | 1-bit output pin is shared with BEEP output pin         |
|               |          | mask option: open-drain                                 |
|               |          | push-pull                                               |
| P20(12)       | OUTPUT-A | 2-bit bidirection I/O port                              |
|               |          | mask option: open-drain                                 |
|               |          | push-pull                                               |
| TONE          |          | DTMF output pin                                         |
| TEST          |          | Test pin must be connected to V <sub>ss</sub>           |

#### **FUNCTION DESCRIPTIONS**

#### PROGRAM ROM (4K X 8 bits)

4 K x 8 bits program ROM contains user's program and some fixed data.

The basic structure of program ROM can be divided into 5 parts.

- 1. Address 000h: Reset start address.
- 2. Address 002h 00Ch: 5 kinds of interrupt service rountine entry addresses.
- 3. Address 00Eh-086h: SCALL subroutine entry address, only available at 00Eh,016h,01Eh,026h, 02Eh, 036h, 03Eh, 046h, 04Eh, 056h, 05Eh, 066h, 06Eh, 076h,07Eh, 086h.
- 4. Address 000h 7FFh: LCALL subroutine entry address
- 5. Address FE0h FFFh : The data region for 5-to-8 bits data conversion table .
- 6. Address 000h FFFh: Except used as above function, the other region can be used as user's program region.

| address | 4096 x 8 bits                                                 |
|---------|---------------------------------------------------------------|
| 000h    | Reset start address                                           |
| 002h    | INTO; External interrupt service routine entry address        |
| 004h    | SIOI; SIO interrupt service routine entry address             |
| 006h    | TRGA; Timer/counterA interrupt service routine entry address  |
| 008h    | TRGB; Timer/counter B interrupt service routine entry address |
| 00Ah    | TBI; Time base interrupt service routine entry address        |
| 00Ch    | INT1; External interrupt service routine entry address        |
| 00Eh    | CCATT 1 2 11 4 11                                             |
| 086h    | SCALL, subroutine call entry address                          |
|         |                                                               |
| •       |                                                               |
| FE0h    |                                                               |
| FFFh    | Data conversion table for "OUT12" instruction                 |



User's program and fixed data are stored in the program ROM. User's program is according the PC value to send next executed instruction code . Fixed data can be read out by two ways.

#### (1) Table-look-up instruction:

Table-look-up instruction is depended on the Data Pointer (DP) to indicate to ROM address, then to get the ROM code data.

```
\begin{tabular}{lll} LDAX & Acc \leftarrow ROM[DP]_L \\ LDAXI & Acc \leftarrow ROM[DP]_H, DP+1 \\ \end{tabular}
```

DP is a 12-bit data register which can store the program ROM address to be the pointer for the ROM code data. first, user load ROM address into DP by instruction "LDADPL, LDADPM, LDADPH". then user can get the lower nibble of ROM code data by instruction "LDAX" and higher nibble by instruction "LDAXI".

PROGRAM EXAMPLE: Read out the ROM code of address 777h by table-look-up instruction.

```
LDIA #07h;
STADPL
              ; [DP]_{L} \leftarrow 07h
             ; [DP]_{M} \leftarrow 07h
STADPM
              ; [DP]_{H} \leftarrow 07h, Load DP=777h
STADPH
LDL #00h;
LDH #03h;
LDAX
              ; ACC \leftarrow 6h
STAMI
              ; RAM[30] \leftarrow 6h
LDAXI
              ; ACC \leftarrow 5h
STAM
              ; RAM[31] \leftarrow 5h
ORG 777h
DATA 56h;
```

#### (2) 5-to-8 bits data conversion instruction:

```
OUT12: IF CF=1 Port1= ROM[FF0h+RAM[HL]]<sub>L</sub>; Port2= ROM [FF0h+RAM[HL]]<sub>H</sub> IF CF=0 Port1= ROM[FE0h+RAM[HL]]<sub>L</sub>; Port2= ROM[FE0h+RAM[HL]]<sub>H</sub>
```

5-to-8 bits data conversion instruction can read fixed data from data conversion table (FE0-FFF) out to Port1 and Port2 synchronously, the 5-bit data is composed by CF and RAM data which specified by HL, when CF=1, the 8-bit data is located in address of FF0h+ RAM[HL] of ROM, in the other way, when CF=0, the 8-bit data is located in address FE0h + RAM[HL] of ROM.

PROGRAM EXAMPLE: To output port1, port2 data by 5-to-8 bits data conversion instruction.

```
LDL #00h;

LDH #03h;

LDIA #00h;

STAM; RAM[30] \leftarrow 00h

TTCFS; CF \leftarrow 1

OUT12;

:

:

ORG FF0h

DATA 40h;

7Ch;
```



12h; 18h; 2Ch; 09h; 01h; 5Ch; 00h;

### DATA RAM (244-nibble)

There is total 244 - nibble data RAM from address 00 to F3h Data RAM includes 3 parts: zero page region, stacks and data area.



#### ZERO- PAGE:

From 00h to 0Fh is the location of zero-page . It is used as the pointer in zero -page addressing mode for the instruction of "STD #k,y; ADD #k,y; CLR y,b; CMP y,b".

PROGRAM EXAMPLE: To wirte immediate data "07h" to address "03h" of RAM and to clear bit 2 of RAM. STD #07h, 03h; RAM[03]  $\leftarrow$  07h CLR 0Eh,2; RAM[0Eh]<sub>2</sub>  $\leftarrow$  0

#### STACK:

There are 13 - level (maximum) stack for user using for subroutine (including interrupt and CALL). User can assign any level be the starting stack by giving the level number to stack pointer (SP).

When user using any instruction of CALL or subroutine, before entry the subroutine, the previous PC address will be saved into stack until return from those subroutines, the PC value will be restored by the data saved in stack.

#### DATA AREA:

Except the special area used by user, the whole RAM can be used as data area for storing and loading general data.

#### ADDRESSING MODE

(1) Indirect addressing mode:



Indirect addressing mode indicates the RAM address by specified HL register.

For example: LDAM ;  $Acc \leftarrow RAM[HL]$ STAM ;  $RAM[HL] \leftarrow Acc$ 

### (2) Direct addressing mode:

Direct addressing mode indicates the RAM address by immediate data .

For example: LDA x ; Acc $\leftarrow$  RAM[x] STA x ; RAM[x]  $\leftarrow$  Acc

#### (3) Zero-page addressing mode

For zero-page region, user can using direct addressing to write or do any arithematic, comparsion or bit manupulated operation directly.

For example: STD #k,y; RAM[y]  $\leftarrow \#k$ 

ADD #k,y; RAM[y]  $\leftarrow$  RAM[y] + #k

#### **PROGRAM COUNTER (4K ROM)**

Program counter ( PC ) is composed by a 12-bit counter, which indicates the next executed address for the instruction of program ROM.

For a 4K - byte size ROM, PC can indicate address form 000h - FFFh, for BRANCH and CALL instrcutions, PC is changed by instruction indicating.

#### (1) Branch instruction:

#### SBR a

Object code: 00aa aaaa

Condition: SF=1; PC  $\leftarrow$  PC <sub>11.6</sub>, (branch condition satisified)

SF=0; PC← PC +1( branch condition not satisified)

#### LBR a

Object code: 1100 aaaa aaaa aaaa

Condition: SF=1; PC  $\leftarrow$  a (branch condition satisified)

SF=0; PC  $\leftarrow$  PC + 2 (branch condition not satisfied)

#### (2) Subroutine instruction:

#### SCALL a

Object code: 1110 nnnn

Condition:  $PC \leftarrow a$ ; a=8n+6; n=1..15; a=86h, n=0





#### LCALL a

Object code: 0100 0 aaa aaaa aaaa

Condition:  $PC \leftarrow a$ 

PC 0 a a a a a a a a a a a

#### **RET**

Object code: 0100 1111

Condition:  $PC \leftarrow STACK[SP]; SP + 1$ 

PC The return address stored in stack

#### RT I

Object code: 0100 1101

Condition : FLAG. PC  $\leftarrow$  STACK[SP]; EI  $\leftarrow$  1; SP + 1

PC The return address stored in stack

#### (3) Interrupt acceptance operation:

When an interrupt is accepted, the original PC is pushed into stack and interrupt vector will be loaded into PC, The interrupt vectors are as following:

**INT0** (External interrupt from P8.2)

**SIOI** (SIO interrupt)

TRGA (Timer A overflow interrupt)

TRGB (Time B overflow interrupt)

**TBI** (Time base interrupt)

**INT1** (External interrupt from P8.0)

#### (4) Reset operation:



#### (5) Other operations:

For 1-byte instruction execution: PC + 1For 2-byte instruction execution: PC + 2

#### **ACCUMULATOR**

Accumulator is a 4-bit data register for temporary data . For the arithematic, logic and comparative opertion ..., ACC plays a role which holds the source data and result .

#### **FLAGS**

There are four kinds of flag, CF ( Carry flag ), ZF ( Zero flag ), SF ( Status flag ) and GF ( General flag ), these 4 1-bit flags are affected by the arithematic, logic and comparative .... operation . All flags will be put into stack when an interrupt subroutine is served, and the flags will be restored after RTI instruction executed .

#### (1) Carry Flag (CF)

The carry flag is affected by following operation:

- a. Addition: CF as a carry out indicator, when the addition operation has a carry-out, CF will be "1", in another word, if the operation has no carry-out, CF will be "0".
- b. Subtraction: CF as a borrow-in indicator, when the subtraction operation must has a borrow, in the CF will be "0", in another word, if no borrow-in, CF will be "1".
- c. Comparision: CF is as a borrow-in indicator for Comparision operation as the same as subtraction operation.
- d. Rotation: CF shifts into the empty bit of accumulator for the rotation and holds the shift out data after rotation.
- e. CF test instruction: For TFCFC instruction, the content of CF sends into SF then clear itself "0". For TTSFC instruction, the content of CF sends into SF then set itself "1".

#### (2) Zero Flag (ZF)

ZF is affected by the result of ALU, if the ALU operation generate a "0" result, the ZF will be "1",otherwise , the ZF will be "0".

#### (3) Status Flag (SF)

The SF is affected by instruction operation and system status.

- a. SF is initiated to "1" for reset condition.
- b. Branch instruction is decided by SF, when SF=1, branch condition will be satisified, otherwise, branch condition will not be satisified by SF = 0.



#### (4) General Flag (GF)

GF is a one bit general purpose register which can be set, clear, test by instruction SGF, CGF and TGS.

#### PROGRAM EXAMPLE:

Check following arithematic operation for CF, ZF, SF

|            | CF | ZF | SF |
|------------|----|----|----|
| LDIA #00h; | -  | 1  | 1  |
| LDIA #03h; | -  | 0  | 1  |
| ADDA #05h; | -  | 0  | 1  |
| ADDA #0Dh; | -  | 0  | 0  |
| ADDA #0Eh; | -  | 0  | 0  |

#### **ALU**

The arithematic operation of 4 - bit data is performed in ALU unit. There are 2 flags can be affected by the result of ALU operation, ZF and SF. The operation of ALU can be affected by CF only.

#### **ALU STRUCTURE**

ALU supported user arithematic operation function, including: addition, subtraction and rotaion.



#### **ALU FUNCTION**

#### (1) Addition:

For instruction ADDAM, ADCAM, ADDM #k, ADD #k,y .... ALU supports addition function. The addition operation can affect CF and ZF. For addition operation, if the result is "0", ZF will be "1", otherwise, not equal "0", ZF will be "0", When the addition operation has a carry-out. CF will be "1", otherwise, CF will be "0".

# **EXAMPLE:**

| Operation | Carry | Zero |
|-----------|-------|------|
| 3+4=7     | 0     | 0    |
| 7+F=6     | 1     | 0    |
| 0+0=0     | 0     | 1    |
| 8+8=0     | 1     | 1    |



#### (2) Subtraction:

For instruction SUBM #k, SUBA #k, SBCAM, DECM... ALU supports user subtraction function. The subtraction operation can affect CF and ZF, For subtraction operation, if the result is negative, CF will be "0", it means a borrow out, otherwise, if the result is positive, CF will be "1". For ZF, if the result of subtraction operation is "0", the ZF will be "1", otherwise, ZF will be "1".

#### **EXAMPLE:**

| Operation      | Carry | Zero |
|----------------|-------|------|
| 8-4=4          | 1     | 0    |
| 7-F = -8(1000) | 0     | 0    |
| 9-9=0          | 1     | 1    |

#### (3) Rotation:

There are two kinds of rotation operation, one is rotation left, the other is rotation right.

RLCA instruction rotates Acc value to left, shift the CF value into the LSB bit of Acc and the shift out data will be hold in CF.



RRCA instruction operation rotates Acc value to right, shift the CF value into the MSB bit of Acc and the shift out data will be hold in CF.



PROGRAM EXAMPLE: To rotate Acc right and shift a "1" into the MSB bit of Acc .

TTCFS;  $CF \leftarrow 1$ 

RRCA; rotate Acc right and shift CF=1 into MSB.

#### **HL REGISTER**

HL register are two 4-bit registers, they are used as a pair of pointer for the address of RAM memory and also 2 independent temporary 4-bit data registers. For some instruction, L register can be a pointer to indicate the pin number ( Port4 - Port7 ) .

#### HL REGISTER STRUCTURE





#### **HL REGISTER FUNCTION**

(1) For instruction: LDL #k, LDH #k, THA, THL, INCL, DECL, EXAL, EXAH, HL register used as a temporary register.

```
PROGRAM EXAMPLE: Load immediate data "5h" into L register, "Dh" into H register. LDL #05h; LDH #0Dh;
```

(2) For instruction LDAM, STAM, STAMI .., HL register used as a pointer for the address of RAM memory.

```
PROGRAM EXAMPLE: Store immediate data #Ah into RAM of address 35h. LDL #5h; LDH #3h; STDMI #0Ah; RAM[35] ← Ah
```

(3) For instruction: SELP, CLPL, TFPL, L regieter be a pointer to indicate the bit of I/O port.

```
When LR = 0 - 3, indicate P4.0 - P4.3.

LR = 4 - 7, indicate P5.0 - P5.3

LR = 8 - B, indicate P6.0 - P6.3

LR = C - F, indicate P7.0 - P7.3

PROGRAM EXAMPLE: To set bit 2 of Port6 to "1"

LDL #0Ah;

SEPL; P6.2 \leftarrow 1
```

#### STACK POINTER (SP)

Stack pointer is a 4-bit register which stores the present stack level number.

Before using stack, user must set the SP value first, CPU will not initiate the SP value after reset condition . When a new subroutine is accepted, the SP will be decreased one automatically, in another word, if returning from a subroutine, the SP will be increased one .

The data transfer between ACC and SP is by instruction of "LDASP" and "STASP".

#### **DATA POINTER (DP)**

Data pointer is a 12-bit register which stores the address of ROM can indicate the ROM code data specified by user (refer to data ROM).

### **CLOCK AND TIMING GENERATOR**

The clock generator is supported by a single clock system, the clock source comes from crystal (resonator), the working frequency range is 480 K Hz to 4 MHz depending on the working voltage.

### **CLOCK AND TIMING GENERATOR STRUCTURE**

The clock generator connects outside components (crystal or resonator by XIN and XOUT pin for crystal osc type) the clock generator generates a basic system clock "fc".



When CPU sleeping, the clock generator will be stoped until the sleep condition released. The system clock control generates 4 basic phase signals (S1, S2, S3, S4) and system clock.



Crystal connection

#### **CLOCK AND TIMING GENERATOR FUNCTION**

The frequency of fc is the oscillation frequency for XIN, XOUT by crystal (resonator).

When CPU sleeps, the XOUT pin will be in "high" state.

The instruction cycle equal 8 basic clock fc.

1 instructure cycle = 8 / fc

#### TIMING GENERATOR AND TIME BASE

The timing generator produces the system clock from basic clock pulse which can be normal mode or slow mode clock.

1 instruction cycle = 8 basic clock pulses

There are 22 stages time base.



When working in the single clock mode, the timebase clock source is come from fc.

Time base provides basic frequency for following function:

- 1. TBI (time base interrupt).
- 2. Timer/counter, internal clock source.
- 3. Warm-up time for sleep mode releasing.



#### TIME BASE INTERRUPT (TBI)

The time base can be used to generate a fixed frequency interrupt . There are 8 kinds of frequencies can be selected by setting "P25"

Single clock mode



#### TIMER / COUNTER (TIMERA, TIMERB)

Timer/counters can support user three special functions:

- 1. Even counter
- 2. Timer.
- 3. Pulse-width measurement.

These three functions can be executed by 2 timer/counter independently.

For timerA, the counter data is saved in timer register TAH, TAM, TAL, which user can set counter initial value and read the counter value by instruction "LDATAH(M,L), STATAH(M,L)" and timer register is TBH, TBM, TBL and W/R instruction "LDATBH (M,L), STATBH (M,L)".

The basic structure of timer/counter is composed by two same structure counter, these two counters can be set initial value and send counter value to timer register, P28 and P29 are the command ports for timerA and timer B, user can choose different operation mode and different internal clock rate by setting these two ports. When timer/counter overflow, it will generate a TRGA(B) interrupt request to interrupt control unit.





#### TIMER/COUNTER CONTROL

P8.1/TRGB, P8.3/TRGA are the external timer inputs for timerB and timerA, they are used in event counter and pulse-width measurement mode.

Timer/counter command port: P28 is the command port for timer/counterA and P29 is for the timer/counterB.



Initial state: 0000

Port 29 3 2 1 0 TMSB IPSB

Initial state: 0000

| TIMER/COUNTER MODE SELECTION |                              |  |
|------------------------------|------------------------------|--|
| TMSA (B)                     | Function description         |  |
| 0.0                          | Stop                         |  |
| 0 1                          | Event counter mode           |  |
| 1 0                          | Timer mode                   |  |
| 1 1                          | Pulse width measurement mode |  |

| INTERNAL PULSE-RATE SELECTION |                        |  |
|-------------------------------|------------------------|--|
| IPSA(B)                       | Function description   |  |
| 0.0                           | XIN/2 <sup>10</sup> Hz |  |
| 0 1                           | XIN/2 Hz               |  |
| 1 0                           | XIN/2 <sup>18</sup> Hz |  |
| 1 1                           | XIN/2 <sup>22</sup> Hz |  |

#### TIMER/COUNTER FUNCTION

Each timer/counter can execute any one of these functions independly.

#### **EVENT COUNTER MODE**

For event counter mode, timer/counter increases one at any rising edge of P8.1/TRGB for timerA(P8.3/TRGA for timerA). When timerB(A) counts overflow, it will give interrupt control an interrupt request TRGB(A).





PROGRAM EXAMPLE: Enable timerA with P28.

LDIA #0100B;

OUTA P28; Enable timerA with event counter mode

#### TIMER MODE

For timer mode ,timer/counter increase one at any rising edge of internal pulse . User can choose 4 kinds of internal pulse rate by setting IPSB for timerB (IPSA for timerA).

When timer/counter counts overflow, TRGB (TRGA) will be generated to interrupt control unit.



 $PROGRAM\ EXAMPLE:\ To\ generate\ TRGA\ interrupt\ request\ after\ 60\ ms\ with\ system\ clock\ XIN=4MHz$ 

LDIA #0100B:

EXAE; enable mask 2

EICIL 110111B; interrupt latch  $\leftarrow$ 0, enable EI

LDIA #06H; STATAL; LDIA #01H; STATAM; LDIA #0FH; STATAH;

LDIA #1000B;

OUTA P28; enable timerA with internal pulse rate: XIN/2<sup>10</sup> Hz

NOTE: The preset value of timer/counter register is calculated as following procedure.

Internal pulse rate:  $XIN/2^{10}$ ; XIN = 4MHz

The time of timer counter count one =  $2^{10}$  /XIN = 1024/4000=0.256ms

The number of internal pulse to get timer overflow = 60 ms / 0.256 ms = 234.375 = 0 EAH

The preset value of timer/counter register = 1000H - 0EAH = F16H

#### PULSE WIDTH MEASUREMENT MODE

For the pulse width measurement mode, the counter only incressed by the rising edge of internal pulse rate as external timer/counter input (P8.1/TRGB, P8.3/TRGA), interrupt request will be generated as soon as timer/counter count overflow.





PROGRAM EXAMPLE: Enable timerA by pulse width measurement mode .

LDIA #1100b:

OUTA P28; Enable timerA with event counter mode.

#### INTERRUPT FUNCTION

There are 6 interrupt sources, 2 external interrupt sources, 4 internal interrupt sources. Multiple interrupts are admitted according the priority.

| Type     | Interrupt source                 | Priority | Interrupt<br>Latch | Interrupt<br>Enable condition | Program ROM entry address |
|----------|----------------------------------|----------|--------------------|-------------------------------|---------------------------|
| External | External interrupt(INT0)         | 1        | IL5                | EI=1                          | 002h                      |
| Internal | SIO interrupt (SIOI)             | 2        | IL4                | EI=1, MASK3=1                 | 004h                      |
| Internal | TimerA overflow interrupt (TRGA) | 3        | IL3                | EI=1, MASK2=1                 | 006h                      |
| Internal | TimerB overflow interrupt (TRGB) | 4        | IL2                | EI=1, MASK1=1                 | 008h                      |
| Internal | Time base interrupt(TBI)         | 5        | IL1                |                               | 00Ah                      |
| External | External interrupt(INT1)         | 6        | IL0                | EI=1,MASK0=1                  | 00Ch                      |

#### INTERRUPT STRUCTURE



#### Interrupt controller:

ILO-IL5 : Interrupt latch . Hold all interrupt requests from all interrupt sources. ILr can not be

set by program, but can be reset by program or system reset, so IL only can decide

which interrupt source can be accepted.

MASK0-MASK3 : Except INTO, MASK register can promit or inhibit all interrupt sources.

EI : Enable interrupt Flip-Flop can promit or inhibit all interrupt sources, when inter-

rupt happened, EI is cleared to "0" automatically, after RTI instruction happened,

EI will be set to "1" again.



Priority checker: Check interrupt priority when multiple interrupts happened.

#### INTERRUPT FUNCTION

The procedure of interrupt operation:

- 1. Push PC and all flags to stack.
- 2. Set interrupt entry address into PC.
- 3. Set SF=1.
- 4. Clear EI to inhibit other interrupts happened.
- 5. Clear the IL for which interrupt source has already be accepted.
- 6. To excute interrupt subroutine from the interrupt entry address.
- 7. CPU accept RTI, restore PC and flags from stack . Set EI to accept other interrupt requests.

PROGRAM EXAMPLE: To enable interrupt of "INTO, SIOI, TRGA"

LDIA #1100B;

EXAE; set mask register "1100B"

EICIL 111111B; enable interrupt F.F.

#### POWER SAVING FUNCTION (Sleep / Hold function)

During sleep and hold condition, CPU holds the system's internal status with a low power consumption, for the sleep mode, the system clock will be stoped in the sleep condition and system need a warm up time for the stability of system clock running after wakeup. In the other way, for the hold mode, the system clock does not stop at all and it does not need a warm-up time any way.

The sleep and hold mode is controlled by Port 16 and released by  $P0(0..3)/\overline{WAKEUP0..3}$  or  $\overline{P14.0}/\overline{WAKEUPE}$ .

| SWWT | Set wake-up          | warm-up time |
|------|----------------------|--------------|
| 0 0  | 2 <sup>18</sup> /XIN |              |
| 0 1  | 2 14 /XIN            |              |
| 10   | 2 <sup>16</sup> /XIN |              |
| 1 1  | Hold mode            |              |

| WM | Set wake-up release mode      |
|----|-------------------------------|
| 0  | Wake-up in edge release mode  |
| 1  | Wake-up in level release mode |

| SE | Enable sleep/hold        |
|----|--------------------------|
| 0  | Reserved                 |
| 1  | Enable sleep / hold mode |

#### Sleep and hold condition:

- 1. Osc stop (sleep only) and CPU internal status held.
- 2. Internal time base clear to "0".
- 3. CPU internal memory ,flags, register, I/O held original states.
- 4. Program counter hold the executed address after sleep release.

#### Release condition:

- 1. Osc start to oscillating.(sleep only).
- 2. Warm-up time passing (sleep only).
- 3. According PC to execute the following program.



There are two kinds of sleep/hold release mode.

#### 1. Edge release mode:

Release sleep/hold condition by the falling edge of any one of  $P0(0..3)/\overline{WAKEUP0..3}$  or by the rising edge of  $\overline{P14.0}/WAKEUPE$ .

#### 2. Level release mode:

Release sleep/hold condition by the low level of any one of  $P0(0..3)/\overline{WAKEUP0..3}$  or by the high level of  $\overline{P14.0}/\overline{WAKEUPE}$ .

The P14.0 responses the wakeup status and it's function as following:



WAKEUP STATUS = (P0.0+M0)(P0.1+M1)(P0.2+M2)(P0.3+M3)(P14.0)

The M0..3 are the mask options of P0(0..3)/WAKEUP0..3 for wakeup function. When M0..3 is equal to 0, the wakeup mask option is enabled. Otherwise, the wakeup mask option is disabled.

If user want to start the sleep/hold operation with the WAKEUP STATUS being high, the sleep/hold function will be released immediately. So, to start the sleep/hold operation in level release mode, the WAKEUP STATUS must be recognized to low by program.

PROGRAM EXAMPLE: Detect the WAKEUP STATUS to start the sleep/hold operation in the level release mode.

WAKE: TFP P14.0 ; wait the WAKEUP STATUS goes to low

B WAKE

LDIA #1100B ;enable sleep operation in level release mode, warm-up time is 2<sup>18</sup>/XIN

OUTA P16

Note: There are 4 independent mask option (M0..3) for wakeup function in EM73492. So, the wakeup function of P0(0..3)/WAKEUP0..3 are enabled or disabled independently.



#### **BEEP TONE GENERATOR**

Beep tone generator can generate a series of square wave in audiable frequency.

The beep tone output pin is shared with P20.0 . when beep tone is disable, P20.0 is a general purpose output pin, in the other way, if beep tone enable, P20.0 is the beep tone output pin.



P19 is the command port for beep tone generator. The bit0,1 are called BFS, it is the selection bit for the beep tone output frequency. The bit 3 is called BE, it controls the enable and the disable of beep tone.

Port 19 3 2 1 0

| BE | BFS |
| Initial state : 0x00

| BE | Beep tone enable |
|----|------------------|
| 0  | Disable          |
| 1  | Enable           |

According to the different clock frequency, XIN, beep tone has following selection.

| BFS | Beep tone freq. selection              |
|-----|----------------------------------------|
| 0 0 | XIN / 2 <sup>7</sup> KHz(3.75KHz)      |
| 0 1 | XIN / 2 <sup>8</sup> KHz ( 1.875 KHz ) |
| 1 0 | XIN / 29 KHz ( 937.5 Hz )              |
| 1 1 | XIN / 2 <sup>10</sup> KHz ( 486.75 Hz) |

| BFS | Beep tone freq. selection | 800 KHz   | 960 KHz   |
|-----|---------------------------|-----------|-----------|
| 0 0 | XIN / 28 KHz              | 3.125 KHz | 3.75 KHz  |
| 0 1 | XIN / 29 KHz              | 1.563 KHz | 1.875 KHz |
| 1 0 | XIN / 2 <sup>10</sup> KHz | 781.3 Hz  | 937.5 Hz  |
| 1 1 | XIN / 2 <sup>11</sup> KHz | 390.6 Hz  | 468.8 Hz  |

| 1 1   | AIN / Z | KIZ ( | 400 | J. / J | ΠZ) | 1  | 1   | AII  | N / Z         | VП  | Z |
|-------|---------|-------|-----|--------|-----|----|-----|------|---------------|-----|---|
| XIN = | 480 KHz |       |     |        |     | XI | N = | 800k | <b>X/96</b> 0 | K H | z |
|       |         |       |     |        |     |    |     |      |               |     |   |

| BFS | Beep tone freq. selection | 3.84 MHz  | 3.58 MHz  | 4 MHz     |
|-----|---------------------------|-----------|-----------|-----------|
| 0 0 | XIN / 2 <sup>10</sup> KHz | 3.75 KHz  | 3.496 KHz | 3.906 KHz |
| 0 1 | XIN /2 <sup>11</sup> KHz  | 1.875 KHz | 1.748 KHz | 1.953 KHz |
| 1 0 | XIN /2 <sup>12</sup> KHz  | 937.5 KHz | 874 Hz    | 976.5 KHz |
| 1 1 | XIN /2 <sup>13</sup> KHz  | 468.8 KHz | 437 Hz    | 488.2 KHz |

XIN = 3.58 M / 3.84 M / 4 M Hz

PROGRAM EXAMPLE: To send 1.875KHz beep tone with system clock 480 KHz

LDIA #1111B

OUTA P20 ; CLEAR BEEP TONE OUTPUT

LDIA #1001B

OUTA P19 ; SEND BEEP TONE

:

To send 874Hz beep tone with system clock 3.58 MHz

LDIA #1111B

OUTA P20 ; CLEAR BEEP TONE OUTPUT

LDIA #1010B

OUTA P19 ; SEND BEEP TONE

:



To disable beep tone

LDIA #0000B; OUTA P19

; DISABLE BEEP TONE

:

### **DTMF (Dual Tone Multi Frequency) TONE**

Built-in DTMF generator can generate dialing tone signals for the telephone of dialing tone type. There are two kinds of DTMF tone . One is the group of low frequency, the other is the group of high frequency, each group has 4 kinds of frequency, user can choose single tone frequency or dual tone (combined both low and high frquencies) by setting P13,so user can get 16 kinds of DTMF frequency totally .

DTMF generator contains a low frequency sine - wave generator for generating the DTMF signal which selected by row register and a high frequency sine - wave generator for generating the DTMF signal which selected by column register. Adder is controlled by the bit3 of P13(STE) which controls the dual tone or single tone of DTMF signal.



High frequency sine-wave generator

The bit3 of P13 is the control bit of enable dual or signal tone mode of the DTMF signal.

| Port13 | 3   | 2 | 1 | 0 | _                  |
|--------|-----|---|---|---|--------------------|
| 5      | STE |   |   |   | Initial state:0xxx |
|        |     |   |   |   |                    |

| STE | Single tone enable |
|-----|--------------------|
| 0   | Dual tone mode     |
| 1   | Single tone mode   |

Port 1 and Port 2 is the register for low frequency (row) and high frequency (column) selection

|        | STANDARD | )         | Tone output frequency |           |           |                                |           |           |           |
|--------|----------|-----------|-----------------------|-----------|-----------|--------------------------------|-----------|-----------|-----------|
| ROW    |          | 800 KHz   | Deviation             | 3.58 MHz  | Deviation | 480 KHz<br>960 KHz<br>3.84 MHz | Deviation | 4 MHz     | Deviation |
| 0001   | 697 Hz   | 699.3 Hz  | +.3%                  | 699.2 Hz  | +.3%      | 697.7 Hz                       | +.1%      | 698.0 HZ  | +.1%      |
| 0010   | 770 Hz   | 796.2 Hz  | 1%                    | 771.6 Hz  | +.2%      | 769.2 Hz                       | 1%        | 771.6 Hz  | +.2%      |
| 0100   | 852 Hz   | 854.7 Hz  | +.3%                  | 854.0 Hz  | +.2%      | 851.1 Hz                       | 1%        | 850.3 Hz  | 2%        |
| 1000   | 941 Hz   | 943.4 Hz  | +.2%                  | 940.1 Hz  | 1%        | 937.5 Hz                       | 4%        | 940.0 Hz  | 1%        |
| COLUMN |          |           |                       |           |           |                                |           |           |           |
| 0001   | 1209 Hz  | 1204.8 Hz | 3%                    | 1203.0 Hz | 5%        | 1212.1 Hz                      | +.3%      | 1213.6 Hz | +.4%      |
| 0010   | 1336 Hz  | 1333.3 Hz | 2%                    | 1331.8 Hz | 3%        | 1333.3 Hz                      | 2%        | 1329.8 Hz | 5%        |
| 0100   | 1477 Hz  | 1470.4 Hz | 4%                    | 1472.0 Hz | 3%        | 1481.5 Hz                      | +.3%      | 1470.6 Hz | 4%        |
| 1000   | 1633 Hz  | 1639.3 Hz | +.4%                  | 1645.2 Hz | +.7%      | 1621.6 Hz                      | 7%        | 1623.4 Hz | 6%        |

<sup>\*</sup> This specification are subject to be changed without notice.



DTMF tone is enable by setting Port 1 and Port 2 and bit3 of P13. When user sets in single tone mode, either row or column register must be set by an effective value, otherwise, if any ineffective value or both register are load effective value, tone output will be disable.

In the other way, for dual tone mode, both row and column register must be set by effective value, then the DTMF tone output will output in dual tone mode, otherwise, if either row or column register is set by ineffective value, the DTMF tone output will be disable and there is no tone output.

#### PROGRAM EXAMPLE:

```
(1) Out DTMF tone signal for single tone of 697.7Hz
OUT #1000b,P13; Set in single tone mode
OUT #0000b,P2; Set an ineffective value for column register
OUT #0001b,P1; Enable DTMF signal of 697.7Hz
(2) Out DTMF signal for dual tone by OUT12 instruction (5-to-8 bits data conversion)
LDL #00h;
LDH #03h;
STDMI #0lh; RAM[30] ← 01h
TFCFC; CF ← 0
OUT12; DTMF tone out key "1"
ORG FE0h
DATA 0001 0001b; corresponding to telephone key "1"
DATA 0001 0001b; corresponding to telephone key "4"
:
:
:
```

#### EXTENDED DATA RAM (RAMP)

There are  $512 \times 4$  nibbles extended data RAM for user to used as extra memory space for data bank or telephone . the write/read of extended data RAM is controlled by the address port , data buffer and command port of extended data RAM.

The basic structure of extended RAM is composed of 512 x 4 nibbles RAM ,9-bit extended RAM address port, 4-bit data buffer and a command port . When read/write data, user must assign a address to extended RAM address port, then for write function, user must prepare the written data into data buffer, otherwise, for read function, user can get read data from data buffer after read action . the command port of extended RAM can decide read mode, write mode or standby mode.



A3

A2 | A1



Extended RAM address port: Port18(bit0),Port11 ,Port10,total 9 bits are the extended RAM address port the address port is cleared to "xxx0 0000 0000" during system reset .

Extended RAM data buffer: P12 is the data buffer of extended RAM, when user read/write the extended data RAM the data is put into this buffer and this data buffer will not be distroiled except rewrite P12.

Extended RAM command port: P13 is the command port of extended data RAM, the bit1 of P13 is Read/write control bit (R/W), the bit0 of P13 is extended data RAM operation frequency selection bit(RE).

| R/W | RE | Description   |
|-----|----|---------------|
| *   | 0  | Stand-by mode |
| 0   | 1  | Read mode     |
| 1   | 1  | Write mode    |

#### **EXTENDED RAM FUNCTION**

#### (1) Extended RAM write function:

First, load write address to extended RAM address port and load written data into data buffer, then enable the write active by setting command port to XX11.

#### PROGRAM EXAMPLE:

Clear the extended RAM data from address 000h to 00Fh.

LDIA #0
OUTA P12
OUTA P10;

OUTA P11; Load write address to extended RAM address port

OUTA P18;

OUT #0011B,P13; Enable extended RAM write action

LOOP: CMPIA #0FH;

LBR STANDBY:

INCA:

OUTA P10;

SBR LOOP;

STANDBY: LDIA #0000B;

OUTA P13; Extended RAM into standby mode

#### (2) Extended RAM read function:

First, load read address to extended RAM address port, then enable extended RAM read action by setting command port to XX01. the read data will send into data buffer.

#### PROGRAM EXAMPLE:

Read the extended RAM data of address 00Fh to accumulator. OUT #00H.P10:



OUT #00H,P11;

LDIA #00H; Load read address to extended RAM address port

OUTA P18;

OUT #0001B,P13; Enable extended RAM read action

INA P12; Load read data into ACC from data buffer

#### SERIAL BIDIRECTION INTERFACE (SIO)

SIO function can support user the interface with outside system, There are 6 kinds of SIO function can be used just by programming.

- 1. Transmit mode by internal clock
- 2. Transmit mode by external clock.
- 3. Receive mode by internal clock with leading edge data transfer.
- 4. Receive mode by internal clock with trailing edge data transfer.
- 5. Receive mode by external clock with leading edge data transfer.
- 6. Receive mode by external clock with trailing edge data transfer.

Since SIO function can transfer 4-bit data serially each time, there is a 4-bit buffer for the data to transfer or receive, the SIO port is shared with PORT9: P9.0/SI, it is a SIO data input pin for the SIO receive mode . P9.1/SO, it is a SIO data output pin for the SIO transmit mode. P9.2/ $\overline{SCK}$  is the serial clock pin, it could be internal clock or external clock for both transmit or receive mode . SIO function also can generate interrupt request when the 4-bit data buffer is full ( receive mode ) or empty ( transmit mode ) .

The basic structure of SIO interface is as below, the transmit or receive mode is controlled by the command port (PORT 31), and the SIO status port is Port 14, user can check the SIO status from this port, PORT 15 is the 4-bit SIO buffer, in transmit mode, user put the transfer data in this buffer, then the SIO control will put the data into the shift register and according the  $\overline{SCK}$  to send data out to P9.1/SO, In another way, for receive mode, the outside system will send data from P9.0/SI to shift register, then put data into buffer after 4-bit data transfer ending .





PORT31 is the command port of SIO, user can set the Receive/Transmit mode, external/internal clock source and different bit shift type by this port.

Port 31 3 2 1 0 STC TMS SES SCSS

| SCSS | Serial clock source slection |
|------|------------------------------|
| 0    | Internal clock               |
| 1    | Externai clock               |
| TMS  | Transfer mode selection      |
| 0    | Transmit mode                |
| 1    | Receive mode                 |

|     | (Initial state . 0 0 0 0)              |
|-----|----------------------------------------|
| SES | Shift edge selection                   |
| 0   | Shift at trailing edge of serial clock |
| 1   | Shift at leading edge of serial clock  |
| STC | Serial transfer command                |
| 0   | Serial transfer terminate              |
| 1   | Serial transfer start                  |

(Initial state  $\cdot 0.000$ )

NOTE: When user setting the transfer mode or type, The "STC" must be "0". it means that user can not change the SIO setting during the SIO processing.

PORT 14 is the SIO status port, User can check the SIO processing condition by this port .

Port 14

| I | SIOS | SIOSS | X | X |
|---|------|-------|---|---|
|   | 3    | 2     | 1 | U |

| SIOS | SIO status        |
|------|-------------------|
| 0    | SIO stop working  |
| 1    | SIO still working |

| SIOSS | SIO shift status                  |
|-------|-----------------------------------|
| 0     | SIO bit shift stop working        |
| 1     | SIO bit shift still in processing |

#### PORT 15 is the SIO data buffer.

For transmit mode, user must put the transfer data into P15 before SIO start to transfer data out . For receive mode, user can get the receive data from P15 after SIO transfer finished .

#### SIO transfer clock:

User can choose transfer clock source by P31, there are two kinds of SIO transfer clock sources which is in/out by P9.2/SCK.

Internal clock: Internal clock source is come from the CPU timing generator, it is changed by XIN (system clock) setting.

Internal clock rate: fc/27

External clock: External clock source is come from the outside system. For the CPU executes the SIO function, the high level and the low level of external clock must be 2 instruction cycles at least. so the SIO status flag SIOS, SIOSS will be available after 2 instruction cycles.

#### SIO bit shift edge type:

For transmit mode, there is only one shift type, leading edge shift will be supported . For receive mode, there are two shift type, leading and trailing edge shift will be supported .

1. Leading edge shift mode:

Every bit of SIO data is shifted by the leading edge of serial clock (falling edge of  $\overline{SCK}$ )





2. Trailing edge shift mode:

Every bit of SIO data is shifted by the trailing edge of serial clock (risinging edge of SCK)



#### SIO FUNCTION DESCRIPTION

#### Transmit mode

a. Internal clock type:

Transmit mode with internal clock type transfers 4-bit data from CPU to outside system by a serial clock of CPU internal clock, It's achieved by setting P31 to "X000". since transmit mode only can transfer data by leading edge type . so the bit 1 of P13 (SES) only can be "0".

The operation procedure of transmission mode with internal clock is as following.

- 1. Setting transfer out data to P15(SIO data buffer).
- 2. Setting the transfer mode and type by setting P13 = 0000.
- 3. Start SIO transfer by setting P13 = 1000.
- 4. By the internal clock ( clock rate =  $fc/2^7$  ), SIO control start to transfer 4-bit data out from LSB to MSB to P9.1/SO by shift register at every leading edge of SIO serial clock.
- 5. As SIO processing, user can get the SIO condition by P14.
- 6. When SIO data buffer sending data to shift register and becoming empty, the SIO control unit will send a SIO interrupt request to interrupt service rountine to request next data.
- 7. The SIO interface will be in "wait state" (SCK will stop) until the SIOI interrupt service rountine give next transfer data to the SIO data buffer (P15), then the interrupt will be cleared automatically.
- 8. In another words, Sending STC(P31.3) "0" in SIOI interrupt rountine instead of next transfer data will stop the current SIO operation, user can detect the SIO ending by SCSS (P14.3) be "0".



SIO transmission mode with internal clock

#### PROGRAM EXAMPLE:

(1). To transfer a immediate data (0Ah) out by transmission mode with internal clock



```
LDIA #1010b;
OUTA P15; Load immediate data 0Ah P15(SIO data buffer)
LDIA #0000b;
OUTA P31; sending SIO in transmission mode with internal clock.
LDIA #1000b
OUTA P31; start SIO transfer.
:
```

(2). To terminate the SIO transmission mode with internal clock

```
LDIA #00000b;
OUTA P31: terminate SIO in transmission mode with internal clock.
SIOEND: TTP P14,3;
SBR SIOEND; Check SIO ending; SCSS=0.
```

#### b. External clock type:

Except the transfer clock source is come from outside system, The external clock transmit mode is almost the same as the previous one (internal clock transmit mode). This type is achieved by setting P31 to "X001"; and for the security of SIO execution, each high level and low level of the transfer clock must be 2 instruction cycles at least.

The operation procedure is decript as following:

- 1. Setting transfer out data to P15(SIO data buffer).
- 2. Setting the transfer mode and type by setting P31 = 0.001.
- 3. Start SIO transfer by setting P31 = 1001.
- 4. By the external clock, SIO control unit start to transfer 4-bit data out from LSB to MSB to P9.1/SO by shift register at every leading edge of SIO serial clock.
- 5. As SIO processing user can get the SIO status by P14.
- 6. When shift register has already shifted 4-bit data out and become empty the SIO control unit will send a SIOI interrupt request to interrupt service rountine to request next data.
  - By external clock the data must be set into SIO data buffer before next SIO transfer start . so the transfer clock rate is determinated by the maximum timing from the current interrupt request to the next data written into SIO data buffer.
- 7. The SIO interface will be in wait state until the SIOI interrupt service rountine sending next transfer data to the SIO data buffer (P15) then the interrupt will be cleared automatically.
- 8. In another words, Sending STC(P31.3) "0" in SIOI interrupt rountine instead of next transfer data will stop the current SIO operation user can detect the SIO ending by SCSS (P14.3) be "0".



SIO transmission mode with external clock



#### PROGRAM EXAMPLE:

(1) . To transfer a immediate data (0Ah) out by transmit mode with external clock

LDIA #1010b:

OUTA P15; Load immediate data 0Ah to P15(SIO data buffer)

LDIA #0001b;

OUTA P31; setting SIO in transmission mode with exernal cbck.

LDIA #1001b

OUTA P31; start SIO transer.

:

(2) . To terminate the SIO transmission mode with external clock

LDIA #0001b;

OUTA P31; terminate SIO in transmission mode with external clock.

SIOEND: TTP P14,3

SBR SIOEND; Check SIO ending; SCSS =0.

#### Receive mode

### a. Internal clock type:

Receive mode with internal clock type is transfer 4-bit data from outside system to SIO data buffer of CPU by CPU internal clock. There are two types of internal clock receive modes; one is data shift in leading edge, the other in trailing edge, these different condition settings are decided by P31.

The operation procedure of receive mode with internal clock is as following:

- 1. Setting the receive mode and type by setting P31=0 1 X 0.
- 2. Start SIO transfer by setting P31=1 1 X 0.
- 3. By the internal clock (clock rate=fc/2<sup>7</sup>), SIO control start to transfer 4-bit data into shift register from LSB to MSB from P9.0/SI pin until the shift register is full.
- 4. As SIO processing, user can get the SIO status by P14.
- 5. When the shift register has already shift 4-bit data in and become full, the SIO control will send data to SIO data buffer (P15) and generate a SIOI interrupt request to request to read the data out.
- 6. The SIO interface will in "wait" state (SCK stopped) until CPU read out the data from P15 by the interrupt service rountine, then the interrupt request will be cleared.
- 7. To stop current SIO receive mode is Sending STC(P31.3) "0" in interrupt service rountine, then the current SIO transfer will be stoped, user can detect the SIO ending by SCSS (P14.3) be "0".

NOTE: The leading edge shift mode is shift data in every leading edge of serial clock (the falling edge of SCK, for receive mode of leading edge type, user must put the data in P9.0/SI before the serial clock start.



Read SIO data buffer (P15)

SIO internal clock receive mode with leading edge shift type





SIO external clock receive mode with trailing edge shift type

#### PROGRAM EXAMPLE:

(1a) . To receive 4-bit data by internal clock with leading edge shift mode .

LDIA #0100b;

OUTA P31; setting SIO in internal clock receive mode with leading edge shift type.

LDIA #1100b

OUTA P31; start SIO transfer

(1b). To receive 4-bit data by internal clock with trailing edge shift mode.

LDIA #0110b

OUTA P31; setting SIO in internal clock receive mode with leading edge shift type.

LDIA #1110b

OUTA P31; start SIO transfer.

(2a) . To terminate receive 4-bit data by internal clock with leading edge shift mode .

LDIA #0100b;

OUTA P31; terminate SIO internal clock receive mode with leading edge shift type.

SIOEND: TTP P14,3

SBR SIOEND; Check SIO ending; SCSS=0.

(2b). To terminate receive 4-bit data by internal clock with trailing edge shift mode.

LDIA #0110b:

OUTA P31; terminate SIO internal clock receive mode with trailing edge shift type.

SIOEND: TTP P14,3

SBR SIOEND; Check SIO ending; SCSS=0

#### b. External clock type:

Receive mode with external clock type is transfer 4-bit data from outside system to SIO data buffer of CPU by external clock source, There are two types of external clock receive mode; one is data shift in leading edge, the other in trailing edge, these different condition setting is decided by P31.

The operation procedure of receive mode with external clock is as following.

- 1. Setting the receive mode and type by setting  $P31 = 0.1 \times 1$ .
- 2. Start SIO transfer by setting  $P31 = 11 \times 1$ .
- 3. By the external clock, SIO control start to transfer 4-bit data into shift register from LSB to MSB from P9.0/SI pin until the shift register is full ,then shift register send data to SIO data buffer.
- 4. As SIO processing, user can get the SIO status by P14.
- 5. When SIO data buffer (P15) becomes full, the SIO control unit will send a SIOI interrupt request



request to the interrupt service rountine to request read the transfer data from P15.

- 6. The SIOI interrupt request will be clear after CPU read the data from data buffer.
- 7. To stop current SIO receive mode is Sending STC(P31.3) "0" in interrupt service rountine, then the current SIO transfer will be stoped, user can detect the SIO ending by SCSS (P14.3) be "0".

NOTE: The leading edge shift mode is shift data in every leading edge of serial clock (the falling edge of SCK), for receive mode of leading edge type, user must put the data in P9.0/SI before the serial clock start.



SIO external clock recive mode with leading edge shift type



Read SIO data buffer (P15)

SIO external clock recive mode with trailing edge shift type

# PROGRAM EXAMPLE:

(1a). To receive 4-bit data by external clock with leading edge shift mode.

LDIA #0101b;

OUTA P31; setting SIO in external clock receive mode with leading edge shift type.

LDIA #1101b:

OUTA P31; start SIO transfer.

(1b). To receive 4-bit data by external clock with trailing edge shift mode.

LDIA #0111b

OUTA P31; setting SIO in external clock receive mode with leading edge shift type.

LDIA #1111b;

OUTA P31; start SIO transfer.

(2a). To terminate receive 4-bit data by external clock with leading edge shift mode.

LDIA #0100b;

OUTA P31; terminate SIO in external clock receive mode with leading edge shift type.

SIOEND: TTP P14,3



SBR SIOEND; Check SIO ending; SCSS=0.

(2b). To terminate receive 4-bit data by external clock with trailing edge shift mode.

LDIA #0110b;

OUTA P31; terminate SIO in external clock receive mode with trailing edge shift type.

SIOEND: TTP P14.3

SBR SIOEND; Check SIO ending; SCSS=0.

#### R OPTION FUNCTION FOR I/O PIN

R-option can provide more function for I/O pins. For example, it can be used in keyboard scan for telecom products. When the key is pressed, this I/O pin is a normal I/O pin. When the key in not pressed and the R-option function is enabled, this I/O pin can use as input pin to detect external status of this pad.



R-option can provide the Hi-Z function for output driver and use the weak PMOS to pull high. When the R-option control signal is high, the weak PMOS turns off and the output data latch is in the normal mode. In the case, there are two mask options (push-pull, open-drain) for this I/O pin. When the R-option control signal is low, the weak PMOS turns on and the output data latch is Hi-Z. In this case, the input data is low when this pad connects a  $560 \text{K}\Omega$  external resistor to GND, and the input data is high when this pad is open outside.

#### CONTROL OF R OPTION

R-option control signal can be decided by P20.3. When the CPU resets, the initial value is high in the sleep mode, P20.3 must be set to high and the output pins with R-option function must be clear to low for power saving.

| P20 | 3 | 2 | 1 | 0 |   | Initial value: 1 * * * |
|-----|---|---|---|---|---|------------------------|
|     |   |   |   |   |   |                        |
|     | 0 | * | * | * | : | R-option enable        |
|     | 1 | * | * | * | : | R-option disable       |

ex ; Normal program ; I/O operation

:



```
; R-option operation for P5, P6
OUT
          #0Fh, P5
                        ; let P5 pins pull high
OUT
          #0Fh, P6
                        ; let P6 pins pull high
LDIA
          #00h
OUTA
          P20
                        ; enable R-option function
; Wait 1 ms for deviation capacitor to charge up
INA
          P5
                        ; read P5 pins' external status
          05h
STA
INA
          P6
                        ; read P6 pins' external status
STA
          06h
LDIA
          #08h
OUTA
          P20
                        ; disable R-option function
; Let pins low for sleep mode
          #00h, P5
OUT
OUT
          #00h, P6
; Enable sleep mode
```

#### R OPTION FUNCTION FOR P0 (INPUT ONLY)

There is some difference between I/O pin's and input pin's R-option function. When input pin's R-option mask option is selected, there are two pin's mask options (none, pull-up) can be slected. When the R-option control signal is low, the weak PMOS will turn on and pin's pull-up resistor will turn off (this pin's mask option selects pull-up). In this case, the input data is low when this pad connects a  $560 \text{K}\Omega$  external resistor to GND, and the input data is high when this pad is open outside. When the R-option control signal is high, the weak PMOS will trun off and pin's pull-down resistor will trun on. In sleep mode, user must disable R-option function for power saving. The R-option control signal is also decided by P20.3.





: ; Enable sleep mode

#### **RESETTING FUNCTION**

When CPU in normal working condition and RESET pin holds in low level for three instruction cycles at least, then CPU begins to initialize the whole internal states, and when RESET pin changes to high level, CPU begins to work in normal condition.

The CPU internal state during reset condition is as following table:

| Hardware condition in RESET state            | Initial value     |
|----------------------------------------------|-------------------|
| Program counter                              | 000h              |
| Status flag                                  | 01h               |
| Interrupt enable flip-flop ( EI )            | 00h               |
| MASK0 ,1, 2, 3                               | 00h               |
| Interrupt latch ( IL )                       | 00h               |
| P1, 2, 10,11, 13, 16, 18, 19, 25, 28, 29, 31 | 00h               |
| P3, 4, 5, 6, 7, 8, 9, 20                     | 0Fh               |
| XIN                                          | Start oscillation |

The  $\overline{RESET}$  pin is a hysteresis input pin and it has a pull-up resistor available by mask option. The simplest RESET circuit is connect  $\overline{RESET}$  pin with a capacitor to  $V_{SS}$  and a diode to  $V_{DD}$ .





# **EM73492 I/O PORT DESCRIPTION:**

| Port |   | Input function                       |   | Output function                        | Note          |
|------|---|--------------------------------------|---|----------------------------------------|---------------|
| 0    | Е | Input port, wakeup, R-option         |   |                                        |               |
| 1    |   |                                      | I | DTMF row register                      |               |
| 2    |   |                                      | I | DTMF column register                   |               |
| 3    | Е | Input pin                            | Е | P3.0, output pin                       |               |
| 4    | Е | Input port, R-option                 | Е | Output port                            |               |
| 5    | Е | Input port, R-option                 | E | Output port, R-option                  |               |
| 6    | Е | Input port, R-option                 | E | Output port, R-option                  |               |
| 7    | Е | Input port, R-option                 | Е | Output port, R-option                  |               |
| 8    | Е | Input port, external interrupt input | Е | Output port                            |               |
| 9    | Е | Input port                           | Е | Output port                            |               |
|      |   | P9.0 is shared with SIO input        |   | P9.1 is shared with SIO output         |               |
|      |   | P9.2 is shared with SIO clock        |   | P9.2 is shared with SIO clock          |               |
| 10   |   |                                      | I | Extended RAM address register          | low nibble    |
| 11   |   |                                      | I | Extended RAM address register          | middle nibble |
| 12   |   |                                      | I | Extended RAM data buffer               |               |
| 13   |   |                                      | I | P13(0,1):Extended RAM command register |               |
|      |   |                                      |   | P13.3: DTMF control register           |               |
| 14   | Е | P14.0, input pin, wakeup function    |   |                                        |               |
| 15   |   |                                      |   |                                        |               |
| 16   |   |                                      | I | Sleep mode control register            |               |
| 17   |   |                                      |   |                                        |               |
| 18   |   |                                      | I | Extended RAM address register          | high nibble   |
| 19   |   |                                      | I | BEEP control register                  |               |
| 20   |   |                                      | Е | Output port                            |               |
|      |   |                                      |   | P20.0 : BEEP output pin                |               |
|      |   |                                      | I | P20.3 : R-option control register      |               |
| 21   |   |                                      |   |                                        |               |
| 22   |   |                                      |   |                                        |               |
| 23   |   |                                      |   |                                        |               |
| 24   |   |                                      |   |                                        |               |
| 25   |   |                                      | I | Timebase control register              |               |
| 26   |   |                                      |   |                                        |               |
| 27   |   |                                      |   |                                        |               |
| 28   |   |                                      | I | Timer/counter A control register       |               |
| 29   |   |                                      | I | Timer/counter B control register       |               |
| 30   |   |                                      |   |                                        |               |
| 31   |   |                                      | I | SIO control register                   |               |



#### **ABSOLUTE MAXIMUM RATINGS**

| Items                 | Sym.                 | Ratings                        | Conditions              |
|-----------------------|----------------------|--------------------------------|-------------------------|
| Supply Voltage        | $V_{_{ m DD}}$       | -0.5V to 6V                    |                         |
| Input Voltage         | $V_{_{\mathrm{IN}}}$ | $-0.5$ V to $V_{DD} + 0.5$ V   |                         |
| Output Voltage        | V <sub>o</sub>       | -0.5V to V <sub>DD</sub> +0.5V |                         |
| Power Dissipation     | $P_{_{\rm D}}$       | 300mW                          | $T_{OPR} = 50^{\circ}C$ |
| Operating Temperature | $T_{OPR}$            | 0°C to 50°C                    |                         |
| Storage Temperature   | $T_{STG}$            | -55°C to 125°C                 |                         |

#### RECOMMANDED OPERATING CONDITIONS

| Items               | Sym.                 | Ratings                                                    | Condition              |
|---------------------|----------------------|------------------------------------------------------------|------------------------|
| Supply Voltage      | $V_{_{ m DD}}$       | 2.4V to 5.5V                                               |                        |
| Input Voltage       | $V_{_{\mathrm{IH}}}$ | $0.90 \mathrm{xV}_\mathrm{DD}$ to $\mathrm{V}_\mathrm{DD}$ |                        |
|                     | V <sub>IL</sub>      | $0V \text{ to } 0.10xV_{DD}$                               |                        |
| Operating Frequency | F <sub>C</sub>       | 480K to 4.19MHz                                            | XIN,XOUT (crystal osc) |

# $\textbf{DC ELECTRICAL CHARACTERISTICS} \; (V_{DD} = 5 \pm 0.5 \text{V}, \; V_{SS} = 0 \text{V}, \; T_{OPR} = 25 \, ^{\circ}\text{C})$

|                          | 55 017            |              |                     |                       |      |                                                          |  |  |  |
|--------------------------|-------------------|--------------|---------------------|-----------------------|------|----------------------------------------------------------|--|--|--|
| Parameters               | Sym.              | Min.         | Тур.                | Max.                  | Unit | Conditions                                               |  |  |  |
| Supply current           | I <sub>DD</sub>   | -            | 4.5                 | 5.5                   | mA   | V <sub>DD</sub> =5.5V,no load Fc=4.19MHz(crystal osc)    |  |  |  |
|                          |                   | -            | 0.1                 | 1                     | μΑ   | $V_{DD}$ =5.5V, Sleep mode without voltage detect        |  |  |  |
|                          |                   | -            | 2.5                 | -                     | μΑ   | $V_{DD}$ =2.5V, Sleep mode with voltage detect           |  |  |  |
| Hysteresis voltage       | $V_{\text{HYS+}}$ | $0.50V_{DD}$ | -                   | $0.75V_{DD}$          | V    | RESET, P8, P9,P14, P0                                    |  |  |  |
|                          | V <sub>HYS-</sub> | $0.20V_{DD}$ | -                   | $0.40V_{\mathrm{DD}}$ | V    |                                                          |  |  |  |
| Input current            | I <sub>IH</sub>   | -            | -                   | ±1                    | μΑ   | RESET, P0, V <sub>DD</sub> =5.5V,V <sub>IH</sub> =5.5/0V |  |  |  |
|                          |                   | -            | -                   | ±1                    | μΑ   | Open-drain, $V_{DD}$ =5.5 $V$ , $V_{IH}$ =5.5 $/0V$      |  |  |  |
|                          | $I_{_{\rm IL}}$   | -            | -                   | -1                    | mA   | Push-pull, $V_{DD}$ =5.5V, $V_{IL}$ =0.4V                |  |  |  |
| Output voltage           | V <sub>OH</sub>   | 2.4          | -                   | -                     | V    | Push-pull, $V_{DD}$ =4.5V, $I_{OH}$ =-250 $\mu$ A        |  |  |  |
|                          | V <sub>OL</sub>   | -            | -                   | 0.4                   | V    | $V_{DD}$ =4.5V, $I_{OL}$ =2mA                            |  |  |  |
| Leakage current          | I <sub>LO</sub>   | -            | -                   | 1                     | μΑ   | Open-drain, V <sub>DD</sub> =5.5V, V <sub>O</sub> =5.5V  |  |  |  |
| Input resistor           | R <sub>IN</sub>   | 30           | 90                  | 150                   | ΚΩ   | P0                                                       |  |  |  |
|                          |                   | 100          | 300                 | 450                   | ΚΩ   | RESET                                                    |  |  |  |
| R-option threshold point | V <sub>TH</sub>   | -            | 0.45V <sub>DD</sub> | -                     | V    | $V_{DD} = 3 \sim 5.5 V$                                  |  |  |  |
| R-option weak PMOS       | $R_{WP}$          | -            | 2                   | -                     | ΜΩ   | $V_{\rm DD} = 3 \sim 5.5 \text{ V}$                      |  |  |  |
| resistance               |                   |              |                     |                       |      |                                                          |  |  |  |

# $\textbf{DTMF ELECTRICAL CHARACTERISTICS} \; (V_{DD} = 5 \pm 0.5 \text{V}, \, V_{SS} = 0 \text{V}, \, T_{OPR} = 25 \, ^{\circ}\text{C})$

| Sym.              | Min. | Тур. | Max. | Unit  | Conditions                       |
|-------------------|------|------|------|-------|----------------------------------|
| PEHB              | 1    | 2    | 3    | db    | PEHB=20LOG(COL/ROW)              |
| V <sub>TONE</sub> | 120  | 150  | 180  | mVrms | $RL>10K\Omega, V_{DD}=2.7V(ROW)$ |
| DIS               | -    | -    | 10   | %     | Distortion                       |
| F <sub>TONE</sub> | -    | -    | 0.7  | %     | Stability, except error of OSC   |



# **RESET PIN TYPE**

TYPE RESET-A



# **OSCILLATION PIN TYPE**

TYPE OSC-A



# **INPUT PIN TYPE**

TYPE INPUT-A



#### TYPE INPUT-D



# **OUTPUT PIN TYPE**

TYPE INPUT-F





# **OUTPUT PIN TYPE**

#### TYPE OUTPUT



#### TYPE OUTPUT-A



#### TYPE OUTPUT-B



# I/O PIN TYPE

#### TYPE I/O



#### TYPE I/O-A



#### TYPE I/O-C



TYPE I/O-D





TYPE I/O-E

#### TYPE I/O-F





Path A: For set and clear bit of port instructions, data goes through path A from output data latch to CPU.

Path B: For input and test instructions, data from output pin go through path B to CPU and the output data latch will be set to high.



# **APPLICTION CIRCUIT**





# INSTRUCTION TABLE

# (1) Data Transfer

| Mnemonic | Object code ( binary ) | Operation description                          | Byte | Cycle | F | lag |    |
|----------|------------------------|------------------------------------------------|------|-------|---|-----|----|
|          |                        |                                                |      |       | C | Z   | S  |
| LDA x    | 0110 1010 xxxx xxxx    | $Acc\leftarrow RAM[x]$                         | 2    | 2     | - | Z   | 1  |
| LDAM     | 0101 1010              | $Acc \leftarrow RAM[HL]$                       | 1    | 1     | - | Z   | 1  |
| LDAX     | 0110 0101              | $Acc \leftarrow ROM[DP]_{L}$                   | 1    | 2     | - | Z   | 1  |
| LDAXI    | 0110 0111              | $Acc \leftarrow ROM[DP]_{H}, DP+1$             | 1    | 2     | - | Z   | 1  |
| LDH #k   | 1001 kkkk              | HR←k                                           | 1    | 1     | - | -   | 1  |
| LDHL x   | 0100 1110 xxxx xx00    | $LR \leftarrow RAM[x], HR \leftarrow RAM[x+1]$ | 2    | 2     | - | -   | 1  |
| LDIA #k  | 1101 kkkk              | Acc←k                                          | 1    | 1     | - | Z   | 1  |
| LDL #k   | 1000 kkkk              | LR←k                                           | 1    | 1     | - | -   | 1  |
| STA x    | 0110 1001 xxxx xxxx    | RAM[x]←Acc                                     | 2    | 2     | - | -   | 1  |
| STAM     | 0101 1001              | RAM[HL]←Acc                                    | 1    | 1     | - | -   | 1  |
| STAMD    | 0111 1101              | RAM[HL]←Acc, LR-1                              | 1    | 1     | - | Z   | С  |
| STAMI    | 0111 1111              | RAM[HL]←Acc, LR+1                              | 1    | 1     | - | Z   | C' |
| STD #k,y | 0100 1000 kkkk yyyy    | RAM[y]←k                                       | 2    | 2     | - | -   | 1  |
| STDMI #k | 1010 kkkk              | RAM[HL]←k, LR+1                                | 1    | 1     | - | Z   | C' |
| THA      | 0111 0110              | Acc←HR                                         | 1    | 1     | - | Z   | 1  |
| TLA      | 0111 0100              | Acc←LR                                         | 1    | 1     | - | Z   | 1  |

# (2) Rotate

| Mnemonic | Object code ( binary ) | Operation description                            | Byte | Cycle | Flag |   |    |
|----------|------------------------|--------------------------------------------------|------|-------|------|---|----|
|          |                        |                                                  |      |       | С    | Z | S  |
| RLCA     | 0101 0000              | ←CF←Acc←                                         | 1    | 1     | C    | Z | C' |
| RRCA     | 0101 0001              | $\rightarrow$ CF $\rightarrow$ Acc $\rightarrow$ | 1    | 1     | С    | Z | C' |

# (3) Arithmetic operation

| Mnemonic | Object code ( binary ) | Operation description              | Byte | Cycle | Flag |   |    |
|----------|------------------------|------------------------------------|------|-------|------|---|----|
|          |                        |                                    |      |       | C    | Z | S  |
| ADCAM    | 0111 0000              | $Acc\leftarrow Acc + RAM[HL] + CF$ | 1    | 1     | С    | Z | C' |
| ADD #k,y | 0100 1001 kkkk yyyy    | $RAM[y] \leftarrow RAM[y] + k$     | 2    | 2     | -    | Z | C' |
| ADDA #k  | 0110 1110 0101 kkkk    | Acc←Acc+k                          | 2    | 2     | -    | Z | C' |
| ADDAM    | 0111 0001              | $Acc\leftarrow Acc + RAM[HL]$      | 1    | 1     | 1    | Z | C' |
| ADDH #k  | 0110 1110 1001 kkkk    | HR←HR+k                            | 2    | 2     | -    | Z | C' |
| ADDL #k  | 0110 1110 0001 kkkk    | LR←LR+k                            | 2    | 2     | -    | Z | C' |
| ADDM #k  | 0110 1110 1101 kkkk    | $RAM[HL] \leftarrow RAM[HL] + k$   | 2    | 2     | -    | Z | C' |
| DECA     | 0101 1100              | Acc←Acc-1                          | 1    | 1     | -    | Z | С  |
| DECL     | 0111 1100              | LR←LR-1                            | 1    | 1     | -    | Z | C  |
| DECM     | 0101 1101              | RAM[HL]←RAM[HL]-1                  | 1    | 1     | -    | Z | С  |
| INCA     | 0101 1110              | Acc←Acc + 1                        | 1    | 1     | ı    | Z | C' |



| INCL    | 0111 1110           | LR←LR + 1               | 1 | 1 | - | Z | C' |
|---------|---------------------|-------------------------|---|---|---|---|----|
| INCM    | 0101 1111           | RAM[HL]←RAM[HL]+1       | 1 | 1 | - | Z | C' |
| SUBA #k | 0110 1110 0111 kkkk | Acc←k-Acc               | 2 | 2 | - | Z | C  |
| SBCAM   | 0111 0010           | Acc←RAM[HL] - Acc - CF' | 1 | 1 | С | Z | С  |
| SUBM #k | 0110 1110 1111 kkkk | RAM[HL]←k - RAM[HL]     | 2 | 2 | - | Z | C  |

# (4) Logical operation

| Mnemonic | Object code ( binary ) | Operation description             | Byte | Cycle | F | Flag |    |
|----------|------------------------|-----------------------------------|------|-------|---|------|----|
|          |                        |                                   |      |       | С | Z    | S  |
| ANDA #k  | 0110 1110 0110 kkkk    | Acc←Acc&k                         | 2    | 2     | - | Z    | Z' |
| ANDAM    | 0111 1011              | Acc←Acc & RAM[HL]                 | 1    | 1     | - | Z    | Z' |
| ANDM #k  | 0110 1110 1110 kkkk    | RAM[HL]←RAM[HL]&k                 | 2    | 2     | - | Z    | Z' |
| ORA #k   | 0110 1110 0100 kkkk    | Acc←Acc ¦k                        | 2    | 2     | - | Z    | Z' |
| ORAM     | 0111 1000              | $Acc \leftarrow Acc \mid RAM[HL]$ | 1    | 1     | - | Z    | Z' |
| ORM #k   | 0110 1110 1100 kkkk    | RAM[HL]←RAM[HL]¦k                 | 2    | 2     | - | Z    | Z' |
| XORAM    | 0111 1001              | Acc←Acc^RAM[HL]                   | 1    | 1     | - | Z    | Z' |

# (5) Exchange

| Mnemonic | Object code ( binary ) | Operation description         | Byte | Cycle | Fl | lag |   |
|----------|------------------------|-------------------------------|------|-------|----|-----|---|
|          |                        |                               |      |       | C  | Z   | S |
| EXA x    | 0110 1000 xxxx xxxx    | $Acc \leftrightarrow RAM[x]$  | 2    | 2     | -  | Z   | 1 |
| EXAH     | 0110 0110              | Acc↔HR                        | 1    | 2     | -  | Z   | 1 |
| EXAL     | 0110 0100              | Acc⇔LR                        | 1    | 2     | -  | Z   | 1 |
| EXAM     | 0101 1000              | Acc↔RAM[HL]                   | 1    | 1     | -  | Z   | 1 |
| EXHL x   | 0100 1100 xxxx xx00    | $LR \leftrightarrow RAM[x],$  |      |       |    |     |   |
|          |                        | $HR \leftrightarrow RAM[x+1]$ | 2    | 2     | -  | _   | 1 |

# (6) Branch

| Mnemonic | Object code ( binary ) | Operation description                                             | Byte | Cycle | Flag |   |   |
|----------|------------------------|-------------------------------------------------------------------|------|-------|------|---|---|
|          |                        |                                                                   |      |       | C    | Z | S |
| SBR a    | 00aa aaaa              | If SF=1 then PC $\leftarrow$ PC <sub>11-6</sub> .a <sub>5-0</sub> | 1    | 1     | -    | - | 1 |
|          |                        | else null                                                         |      |       |      |   |   |
| LBR a    | 1100 aaaa aaaa aaaa    | If SF= 1 then PC←a else null                                      | 2    | 2     | -    | - | 1 |

# (7) Compare

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | F | lag |    |
|----------|------------------------|-----------------------|------|-------|---|-----|----|
|          |                        |                       |      |       | C | Z   | S  |
| CMP #k,y | 0100 1011 kkkk yyyy    | k-RAM[y]              | 2    | 2     | C | Z   | Z' |
| CMPA x   | 0110 1011 xxxx xxxx    | RAM[x]-Acc            | 2    | 2     | C | Z   | Z' |
| CMPAM    | 0111 0011              | RAM[HL] - Acc         | 1    | 1     | C | Z   | Z' |
| CMPH #k  | 0110 1110 1011 kkkk    | k - HR                | 2    | 2     | - | Z   | C  |
| CMPIA #k | 1011 kkkk              | k - Acc               | 1    | 1     | C | Z   | Z' |
| CMPL #k  | 0110 1110 0011 kkkk    | k-LR                  | 2    | 2     | - | Z   | С  |

<sup>\*</sup> This specification are subject to be changed without notice.



# (8) Bit manipulation

| Mnemo | nic | Object code ( binary ) | Operation description                       | Byte | Cycle | F | lag |   |
|-------|-----|------------------------|---------------------------------------------|------|-------|---|-----|---|
|       |     |                        |                                             |      |       | C | Z   | S |
| CLM   | b   | 1111 00bb              | $RAM[HL]_b \leftarrow 0$                    | 1    | 1     | - | -   | 1 |
| CLP   | p,b | 0110 1101 11bb pppp    | $PORT[p]_{b} \leftarrow 0$                  | 2    | 2     | - | -   | 1 |
| CLPL  |     | 0110 0000              | $PORT[LR_{3-2}+4]LR_{1-0} \leftarrow 0$     | 1    | 2     | - | -   | 1 |
| CLR   | y,b | 0110 1100 11bb yyyy    | $RAM[y]_b \leftarrow 0$                     | 2    | 2     | - | -   | 1 |
| SEM   | b   | 1111 01bb              | $RAM[HL]_b \leftarrow 1$                    | 1    | 1     | - | -   | 1 |
| SEP   | p,b | 0110 1101 01bb pppp    | $PORT[p]_b \leftarrow 1$                    | 2    | 2     | - | -   | 1 |
| SEPL  |     | 0110 0010              | $PORT[LR_{3-2}+4]LR_{1-0}\leftarrow 1$      | 1    | 2     | - | -   | 1 |
| SET   | y,b | 0110 1100 01bb yyyy    | $RAM[y]_b \leftarrow 1$                     | 2    | 2     | - | -   | 1 |
| TF    | y,b | 0110 1100 00bb yyyy    | $SF \leftarrow RAM[y]_{b}'$                 | 2    | 2     | - | -   | * |
| TFA   | b   | 1111 10bb              | SF←Acc <sub>b</sub> '                       | 1    | 1     | - | -   | * |
| TFM   | b   | 1111 11bb              | SF←RAM[HL] <sub>b</sub> '                   | 1    | 1     | - | -   | * |
| TFP   | p,b | 0110 1101 00bb pppp    | $SF \leftarrow PORT[p]_{b}'$                | 2    | 2     | - | -   | * |
| TFPL  |     | 0110 0001              | $SF \leftarrow PORT[LR_{3-2} + 4]LR_{1-0}'$ | 1    | 2     | - | -   | * |
| TT    | y,b | 0110 1100 10bb yyyy    | $SF \leftarrow RAM[y]_b$                    | 2    | 2     | - | -   | * |
| TTP   | p,b | 0110 1101 10bb pppp    | $SF \leftarrow PORT[p]_{b}$                 | 2    | 2     | - | -   | * |

# (9) Subroutine

| Mnemonic | Object code ( binary ) | Operation description                                     | Byte | Cycle | Flag |   |   |
|----------|------------------------|-----------------------------------------------------------|------|-------|------|---|---|
|          |                        |                                                           |      |       | C    | Z | S |
| LCALL a  | 0100 0aaa aaaa aaaa    | STACK[SP]←PC,                                             | 2    | 2     | -    | - | - |
|          |                        | SP←SP -1, PC←a                                            |      |       |      |   |   |
| SCALL a  | 1110 nnnn              | STACK[SP]←PC,                                             | 1    | 2     | -    | - | - |
|          |                        | $SP \leftarrow SP - 1$ , $PC \leftarrow a$ , $a = 8n + 6$ |      |       |      |   |   |
|          |                        | $(n = 1 \sim 15),0086h (n = 0)$                           |      |       |      |   |   |
| RET      | 0100 1111              | $SP \leftarrow SP + 1, PC \leftarrow STACK[SP]$           | 1    | 2     | -    | - | - |

# (10) Input/output

| Mnemonic | Object code ( binary ) | Operation description        | Byte | Cycle | F | Flag |    |
|----------|------------------------|------------------------------|------|-------|---|------|----|
|          |                        |                              |      |       | С | Z    | S  |
| INA p    | 0110 1111 0100 pppp    | Acc←PORT[p]                  | 2    | 2     | - | Z    | Z' |
| INM p    | 0110 1111 1100 pppp    | RAM[HL]←PORT[p]              | 2    | 2     | - | -    | Z' |
| OUT #k,p | 0100 1010 kkkk pppp    | PORT[p]←k                    | 2    | 2     | - | -    | 1  |
| OUTA p   | 0110 1111 000p pppp    | PORT[p]←Acc                  | 2    | 2     | - | -    | 1  |
| OUTM p   | 0110 1111 100p pppp    | PORT[p]←RAM[HL]              | 2    | 2     | - | -    | 1  |
| OUT12    | 0111 0111              | $PORT[2].PORT[1] \leftarrow$ | 1    | 2     | - | -    | 1  |
|          |                        | ROM[FE0h+CF.RAM[HL]]         |      |       |   |      |    |

# (11) Flag manipulation

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | F | lag |   |
|----------|------------------------|-----------------------|------|-------|---|-----|---|
|          |                        |                       |      |       | C | Z   | S |
| CGF      | 0101 0111              | GF←0                  | 1    | 1     | - | -   | 1 |
| SGF      | 0101 0101              | GF←1                  | 1    | 1     | - | -   | 1 |

<sup>\*</sup> This specification are subject to be changed without notice.



| TFCFC | 0101 0011 | SF←CF', CF←0 | 1 | 1 | 0 | - | * |
|-------|-----------|--------------|---|---|---|---|---|
| TGS   | 0101 0100 | SF←GF        | 1 | 1 | - | - | * |
| TTCFS | 0101 0010 | SF←CF, CF←1  | 1 | 1 | 1 | - | * |
| TZS   | 0101 1011 | SF←ZF        | 1 | 1 | - | - | * |

# (12) Interrupt control

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Fl | ag           |   |
|----------|------------------------|-----------------------|------|-------|----|--------------|---|
|          |                        |                       |      |       | C  | $\mathbf{Z}$ | S |
| CIL r    | 0110 0011 11rr rrrr    | IL←IL & r             | 2    | 2     | -  | -            | 1 |
| DICIL r  | 0110 0011 10rr rrrr    | EIF←0,IL←IL&r         | 2    | 2     | -  | -            | 1 |
| EICIL r  | 0110 0011 01rr rrrr    | EIF←1,IL←IL&r         | 2    | 2     | -  | -            | 1 |
| EXAE     | 0111 0101              | MASK↔Acc              | 1    | 1     | -  | -            | 1 |
| RTI      | 0100 1101              | SP←SP+1,FLAG.PC       | 1    | 2     | *  | *            | * |
|          |                        | ←STACK[SP],EIF ←1     |      |       |    |              |   |

# (13) CPU control

| Mnemonic | Object code ( binary ) | Operation description | Byte | Cycle | Fl | ag           |   |
|----------|------------------------|-----------------------|------|-------|----|--------------|---|
|          |                        |                       |      |       | C  | $\mathbf{Z}$ | S |
| NOP      | 0101 0110              | no operation          | 1    | 1     | -  | -            | - |

# (14) Timer/Counter & Data pointer & Stack pointer control

| Mnemonic | Object code ( binary ) | Operation description  | Byte | Byte Cycle |   | Flag         |   |  |
|----------|------------------------|------------------------|------|------------|---|--------------|---|--|
|          |                        |                        |      |            | C | $\mathbf{Z}$ | S |  |
| LDADPL   | 0110 1010 1111 1100    | Acc←[DP] <sub>L</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDADPM   | 0110 1010 1111 1101    | Acc←[DP] <sub>M</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDADPH   | 0110 1010 1111 1110    | Acc←[DP] <sub>H</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDASP    | 0110 1010 1111 1111    | Acc←SP                 | 2    | 2          | - | Z            | 1 |  |
| LDATAL   | 0110 1010 1111 0100    | Acc←[TA] <sub>L</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDATAM   | 0110 1010 1111 0101    | Acc←[TA] <sub>M</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDATAH   | 0110 1010 1111 0110    | Acc←[TA] <sub>H</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDATBL   | 0110 1010 1111 1000    | Acc←[TB] <sub>L</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDATBM   | 0110 1010 1111 1001    | Acc←[TB] <sub>M</sub>  | 2    | 2          | - | Z            | 1 |  |
| LDATBH   | 0110 1010 1111 1010    | Acc←[TB] <sub>H</sub>  | 2    | 2          | - | Z            | 1 |  |
| STADPL   | 0110 1001 1111 1100    | [DP] <sub>L</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STADPM   | 0110 1001 1111 1101    | [DP] <sub>M</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STADPH   | 0110 1001 1111 1110    | [DP] <sub>H</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STASP    | 0110 1001 1111 1111    | SP←Acc                 | 2    | 2          | - | _            | 1 |  |
| STATAL   | 0110 1001 1111 0100    | [TA] <sub>L</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STATAM   | 0110 1001 1111 0101    | [TA] <sub>M</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STATAH   | 0110 1001 1111 0110    | [TA] <sub>H</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STATBL   | 0110 1001 1111 1000    | [TB] <sub>L</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STATBM   | 0110 1001 1111 1001    | [TB] <sub>M</sub> ←Acc | 2    | 2          | - | -            | 1 |  |
| STATBH   | 0110 1001 1111 1010    | [TB] <sub>H</sub> ←Acc | 2    | 2          | - | -            | 1 |  |



# \*\*\*\* SYMBOL DESCRIPTION

| Symbol                | Description                         | Symbol               | Description                           |
|-----------------------|-------------------------------------|----------------------|---------------------------------------|
| HR                    | H register                          | LR                   | L register                            |
| PC                    | Program counter                     | DP                   | Data pointer                          |
| SP                    | Stack pointer                       | STACK[SP]            | Stack specified by SP                 |
| A <sub>CC</sub><br>CF | Accumulator                         | FLAG                 | All flags                             |
| CF                    | Carry flag                          | ZF                   | Zero flag                             |
| SF                    | Status flag                         | GF                   | General flag                          |
| EI                    | Enable interrupt register           | IL                   | Interrupt latch                       |
| MASK                  | Interrupt mask                      | PORT[p]              | Port ( address : p )                  |
| TA                    | Timer/counter A                     | TB                   | Timer/counter B                       |
| RAM[HL]               | Data memory (address : HL )         | RAM[x]               | Data memory (address : x )            |
| ROM[DP] <sub>L</sub>  | Low 4-bit of program memory         | ROM[DP] <sub>H</sub> | High 4-bit of program memory          |
| [DP],                 | Low 4-bit of data pointer register  | [DP] <sub>M</sub>    | Middle 4-bit of data pointer register |
| [DP] <sub>H</sub>     | High 4-bit of data pointer register | $[TA]_{L}([TB]_{L})$ | Low 4-bit of timer/counter A          |
|                       |                                     |                      | (timer/counter B) register            |
| $[TA]_{M}([TB]_{M})$  | Middle 4-bit of timer/counter A     | $[TA]_{H}([TB]_{H})$ | High 4-bit of timer/counter A         |
|                       | (timer/counter B) register          |                      | (timer/counter B) register            |
| $\leftarrow$          | Transfer                            | $\leftrightarrow$    | Exchange                              |
| +                     | Addition                            | -                    | Substraction                          |
| &                     | Logic AND                           |                      | Logic OR                              |
| ٨                     | Logic XOR                           | 1                    | Inverse operation                     |
|                       | Concatenation                       | #k                   | 4-bit immediate data                  |
| X                     | 8-bit RAM address                   | у                    | 4-bit zero-page address               |
| p                     | 4-bit or 5-bit port address         | b                    | Bit address                           |
| r                     | 6-bit interrupt latch               | PC <sub>11-6</sub>   | Bit 11 to 6 of program counter        |
| LR <sub>1-0</sub>     | Contents of bit assigned by bit     | a <sub>5-0</sub>     | Bit 5 to 0 of destination address for |
|                       | 1 to 0 of LR                        |                      | branch instruction                    |
| LR <sub>3-2</sub>     | Bit 3 to 2 of LR                    |                      |                                       |